草庐IT

MySQL VARCHAR 长度和 UTF-8

全部标签

Ruby on Rails 上传文件问题 奇数 utf8 转换错误

我正在尝试上传文件,但出现以下错误:"\xFF"fromASCII-8BITtoUTF-8我非常关注Rails指南的工作。这是我正在使用的代码。file=params[:uploaded_file]File.open(Rails.root.join('public','images',file.original_filename),'w')do|f|f.write(file.read)end我不明白为什么它不起作用。我做错了什么?更新--这是应用程序跟踪app/controllers/shows_controller.rb:16:in`write'app/controllers/sho

ruby-on-rails - 如何在 ruby​​ 中使用 utf8 的正则表达式

在RoR中,如何使用utf8代码验证中文或日文单词用于发布表单。在GBK编码中,它使用[\u4e00-\u9fa5]+来验证中文单词。在Php中,它使用/^[\x{4e00}-\x{9fa5}]+$/u用于utf-8页面。 最佳答案 Ruby1.8对UTF-8字符串的支持很差。您需要在正则表达式中单独编写字节,而不是完整的代码:>>"acentuação".scan(/\xC3\xA7/)=>["ç"]要匹配您指定的范围,表达式会变得有点复杂:/([\x4E-\x9E][\x00-\xFF])|(\x9F[\x00-\xA5])/#

Ruby:按字节长度限制 UTF-8 字符串

ThisRabbitMQpage状态:Queuenamesmaybeupto255bytesofUTF-8characters.在ruby​​(1.9.3)中,如何按字节数截断UTF-8字符串而不在字符中间中断?生成的字符串应该是符合字节限制的最长可能的有效UTF-8字符串。 最佳答案 对于Rails>=3.0,你有ActiveSupport::Multibyte::Chars限制方法。来自API文档:-(Object)limit(limit)将字符串的字节大小限制为字节数而不破坏字符。当由于某种原因字符串的存储空间有限时可用。例子

ruby - String#encode 未修复 "invalid byte sequence in UTF-8"错误

我知道有很多关于此错误的类似问题,而且我已经尝试了很多,但都没有成功。我遇到的问题涉及字节\xA1并且正在抛出ArgumentError:invalidbytesequenceinUTF-8我尝试了以下但没有成功:"\xA1".encode('UTF-8',:undef=>:replace,:invalid=>:replace,:replace=>"").sub('','')"\xA1".encode('UTF-8',:undef=>:replace,:invalid=>:replace,:replace=>"").force_encoding('UTF-8').sub('','')"

ruby - 相当于 Iconv.conv ("UTF-8//IGNORE",...) 在 Ruby 1.9.X 中?

我正在从远程源读取数据,偶尔会得到一些采用另一种编码的字符。它们并不重要。我想得到一个“最佳猜测”的utf-8字符串,并忽略无效数据。主要目标是获得一个我可以使用的字符串,并且不会遇到以下错误:Encoding::UndefinedConversionError:从ASCII-8BIT到UTF-8的“\xFF”:utf-8中的无效字节序列 最佳答案 我以为是这样:string.encode("UTF-8",:invalid=>:replace,:undef=>:replace,:replace=>"?")将用“?”替换所有已知项。要

错误为 "illegal/malformed utf-8"的 Ruby to_json 问题

我在尝试将散列转换为json字符串时遇到错误JSON::GeneratorError:sourcesequenceisillegal/malformedutf-8。我想知道这是否与编码有关,我怎样才能让to_json只按原样对待\xAE?$irb2.0.0-p247:001>require'json'=>true2.0.0-p247:002>a={"description"=>"iPhone\xAE"}=>{"description"=>"iPhone\xAE"}2.0.0-p247:003>a.to_jsonJSON::GeneratorError:sourcesequenceisi

ruby - 将 UTF-8 设置为 Ruby 1.9.3 的默认值

我正在使用Rails4和Ruby1.9.3我经常使用“奇怪”的字符,所以我必须在所有.rb文件的顶部声明UTF-8编码。有没有办法将UTF-8设置为Ruby1.9.3的默认编码?我尝试了所有答案,但是当运行rakedb:seed并创建一个属性包含非US-ASCII有效字符的对象时,我仍然收到此错误:`blockintrace_on':invalidbytesequenceinUS-ASCII(ArgumentError) 最佳答案 要更改源编码(即您实际编写的源代码所在的编码),您目前必须使用魔术注释:#encoding:utf-8

ruby - 使用 Ruby 将 UTF8 转换为 ANSI

我有一个Ruby脚本,它在Linux机器上远程生成一个UTF8CSV文件,然后通过SFTP将该文件传输到Windows机器。然后我需要用Excel打开这个文件,但是Excel没有UTF8,所以我总是需要在能够将UTF8转换为ANSI的文本编辑器中打开这个文件。我很乐意使用Ruby以编程方式执行此操作并避免手动转换步骤。最简单的方法是什么?PS:我尝试使用iconv但没有成功。 最佳答案 ascii_str=yourUTF8text.unpack("U*").map{|c|c.chr}.join假设您的文本确实适合ascii字符集。

ruby - 如何将 UTF8 组合字符转换为 ruby​​ 中的单个 UTF8 字符?

一些字符,例如Unicode字符'LATINSMALLLETTERCWITHCARON'可以编码为0xC40x8D,但也可以用'LATINSMALLLETTERC'和'COMBININGCARON',即0x630xcc0x8c。更多信息在这里:http://www.fileformat.info/info/unicode/char/10d/index.htm我想知道是否有一个库可以将“LATINSMALLLETTERC”+“COMBININGCARON”转换为“LATINSMALLLETTERCWITHCARON”。或者是否有包含这些转化的表格? 最佳答案

ruby-on-rails - ActionView::Template::Error(不兼容的字符编码:UTF-8 和 ASCII-8BIT)

我正在使用Ruby1.9.2、Rails3.0.4/3.0.5和PhusionPassenger3.0.3/3.0.4。我的模板是用HAML编写的,我使用的是MySQL2gem。我有一个Controller操作,当传递一个具有特殊字符(如变音符号)的参数时,会出现以下错误:ActionView::Template::Error(incompatiblecharacterencodings:UTF-8andASCII-8BIT)错误指向我的HAML模板的第一行,其中包含以下代码:我的理解是,这是因为我有一个UTF-8字符串与一个ASCII-8BIT字符串连接在一起,但我终究无法弄清楚那个